October 12, 2022

## ALUtopModule

#### EC413 Lab4

This module instantiates all other modules and has a mux to perform the various output the correct values depending on the input ALUOp. It performs the following functions:

- 1. MOV
- 2. NOT
- 3. Addition
- 4. Subtraction
- 5. Logical OR
- 6. Logical AND

The modules will all run and upon entering an ALUOp, it enters a MUX generated through case statements and outputs the value of R1. R1 then passes through the NbitReg to store the value of R1 into R0.

## Nbit NOT

This performs a bitwise NOT operation for each bit on the input and puts it into the output. Uses a loop to perform the action.

#### **NbitAdder**

Creates an N-bit ripple carry adder and adds the two inputs. It takes in inputs a, b, and c\_in and its outputs are c\_out and sum.

## **NbitSub**

This module takes two inputs a and b, and input c\_in = 1. It performs the bitwise NOT operation on b by calling Nbit\_NOT. It then will use the Full adder to create a ripple carry to generate the proper values. It returns c out and sum.

#### Nbit OR

This performs a bitwise OR operation between inputs inval1 and inval2. It does this in a loop using the generate function and an or gate and stores the output in outval.

## Nbit AND

This performs a bitwise AND operation between inputs inval1 and inval2. It does this in a loop using the generate function and an and gate and stores the output in outval.

## **NbitReg**

Uses a D Flip-Flop to store the value of the input inval into the output outval. The ALU uses this to store the value of R1 into the register R0.

# Overall Design Hierarchy:

- 1. ALUtopModule
  - a. Nbit\_NOT
  - b. NbitAdder
    - i. FA\_str
  - c. NbitSub
    - i. Nbit\_NOT
    - ii. FA\_str
  - d. Nbit\_OR
  - e. Nbit\_AND
  - f. NbitReg
    - i. Dff

# **ALU Operations**:

| ALUOp  | Function |
|--------|----------|
| 3'b000 | MOV      |
| 3'b001 | NOT      |
| 3'b010 | ADD      |
| 3'b011 | SUB      |
| 3'b100 | OR       |
| 3'b101 | AND      |
| 3'b110 | SLT      |

|                     |       | 000      |            |             |            |            |    |            |             |                                   |            |            |   |            |        |             |           |            |            |            |  |
|---------------------|-------|----------|------------|-------------|------------|------------|----|------------|-------------|-----------------------------------|------------|------------|---|------------|--------|-------------|-----------|------------|------------|------------|--|
| Name                | Value | 0.000 ns |            | 100.000 ns  |            | 200.000 ns |    | 300.000 ns |             | 400.000 ms                        |            | 500.000 ns |   | 600.000 ns |        | 700.000 ns  |           | 800.000 ns |            | 900.000 ns |  |
| > MR2[31:0]         | 0     |          | 1556117170 | 1469750939  | -234383027 | 15         | -1 | -89054399  |             |                                   | -771253939 |            |   | 74565      | 15     | -1277169449 |           |            | -296000302 |            |  |
| > WR3[31:0]         | 0     |          | ō          |             | 111421706  | 10         | 11 | 12325428   | -1767626486 | 626486 0 -1767626486 0 -771253939 |            |            |   | 15         | 74565  | 471323499   | 133115200 |            |            |            |  |
| > ₩ALUOp[2:0]       | х     | x        | 0          | ı           |            |            |    |            |             |                                   | 3          |            |   |            |        | 4           | 5         |            |            |            |  |
| <sup>10</sup> c_in  | 0     |          |            |             |            |            |    |            |             |                                   |            |            |   |            |        |             |           |            |            |            |  |
| ₩clk                | 0     |          |            |             |            |            |    |            |             |                                   |            |            |   |            |        |             |           |            |            |            |  |
| ¼ c_out             | X     |          |            |             |            |            |    |            |             |                                   |            |            |   |            |        |             |           |            |            |            |  |
| > <b>¥</b> R0[31:0] | x     | x        | 1556117170 | -1469750940 | -122961321 | 25         | 10 | -76728971  | 1756086871  | -771253939                        | 996372547  | -771253939 |   | 74550      | -74550 | -107584     | 105587776 |            |            |            |  |
| > <b>V</b> R1[31:0] | х     | ×        | 1556117170 | -146975     | -122961321 | 25         | 10 | -76728971  | 1756086871  | -771253939                        | 996372547  | -771253939 | ۰ | 74550      | -74550 | -1075842049 | 105597776 |            |            |            |  |
| > 💆 verifyALU[31:0] | х     | ×        | 1556117170 | -146975     | -122961321 | 25         | 10 | -76728971  | 1756086871  | -771253939                        | 996372547  | -771253939 | 0 | 74550      | -74550 | -1075842049 | 105587776 |            |            |            |  |
| la error_flag       | х     |          |            |             |            |            |    |            |             |                                   |            |            |   |            |        |             |           |            |            |            |  |
| > ♥N[31:0]          | 32    |          | 92         |             |            |            |    |            |             |                                   |            |            |   |            |        |             |           |            |            |            |  |
|                     |       |          |            |             |            |            |    |            |             |                                   |            |            |   |            |        |             |           |            |            |            |  |
|                     |       |          |            |             |            |            |    |            |             |                                   |            |            |   |            |        |             |           |            |            |            |  |



